草庐IT

网站https 问题记录

全部标签

http - 在 golang 服务器中面临 cors 问题

我在我的Go服务器中编写了这段代码:funcmain(){r:=chi.NewRouter()cors:=cors.New(cors.Options{AllowedOrigins:[]string{"*"},AllowOriginFunc:func(r*http.Request,originstring)bool{returntrue},AllowedMethods:[]string{"GET","POST","PUT","DELETE","OPTIONS"},AllowedHeaders:[]string{"Accept","Authorization","Content-Type"

web - 使用 Golang 构建服务器但在客户端出现问题

这是我的代码:packagemainimport("fmt""net""net/http""os")constRECV_BUF_LEN=1024funchandler(whttp.ResponseWriter,r*http.Request){fmt.Fprint(w,"Test")}funcmain(){http.HandleFunc("/",handler)s:=&http.Server{Addr:":8080",Handler:nil}listener,err:=net.Listen("tcp",s.Addr)iferr!=nil{fmt.Println("Error:",err.

json - 解码 JSON 响应时遇到问题

这个问题在这里已经有了答案:Mystructuresarenotmarshallingintojson[duplicate](3个答案)关闭7年前。这是我第一次尝试使用Go,我觉得我在这里遗漏了一些重要的东西。尝试解码来自网络服务的JSON消息,但我得到的输出是:{响应:{请求:[]}}我真正感兴趣的是请求节点中的数据。我的for循环显然没有被调用,因为数组是空的。我觉得我的结构需要完全按照它们在网络服务中出现的方式声明吗?示例JSON:{"response":{"requests":[{"request":{}},{"request":{"id":589748,"image_thum

Go包导入问题

我的文件夹设置如下:-src--bitbucket.org---eagleamulet----myFirst.go(packagemain)-----utils------tempconv-------tempconv.go(packagetempconv)但是我无法将tempconv包添加到myFirst.go我的Go环境设置看起来没问题,所以我不确定这里出了什么问题:temppackagegoenv非常感谢任何指点!谢谢EA 最佳答案 一直忘记限定函数名称。如果我执行了.导入到当前命名空间,它就会起作用。

go - 关于goroutine并发的问题

我在goroutine并发方面遇到了一些麻烦。在我的期望中,它应该异步运行并几乎同时打印出来,但它真正做的是等待运行我的测试代码packagemaintypebatchD[]stringvarcBD=make(chanbatchD,6)funcmain(){runtime.GOMAXPROCS(runtime.NumCPU())data:=[][]string{}data=append(data,[]string{"71","40348270","6","win888e","6","1","N","127.0.0.1"})data=append(data,[]string{"71","

go - 为什么使用自定义 log.Logger 记录到文件会失败?

我无法让我的程序从main()之外的函数写入日志文件我确实看到了https://stackoverflow.com/a/19966217/4374801这很相似,但没有解决我的确切问题。以下是我正在做的事情的重要部分:var(Info*log.LoggerError*log.Logger)funcinit(){//setuplogfilefileHandle,err:=os.OpenFile("/var/log/checkcert",os.O_WRONLY|os.O_CREATE|os.O_APPEND,0644)iferr!=nil{log.Fatal(err)}//defertoc

go - Zap 记录器打印到控制台和日志文件

我已将Zap与我的go应用程序集成,我们将日志打印在两个日志文件中,我还使用Lumberjack进行日志轮换。但我也试图在控制台中显示日志,但这种情况下运气不好。以下是我在logger.go中的代码var(Logger*zap.LoggerN2n*zap.Logger)typeWriteSyncerstruct{io.Writer}func(wsWriteSyncer)Sync()error{returnnil}funcInitLogging(modestring){varcfgzap.ConfigvarlogName="abc.log"varslogName="n2n.log"ifm

go - 简单 HTTPS 请求 : Golang returns 505, Python 和 Chrome 工作

我正在尝试使用最简单的golang代码执行HTTPgetoverTLS,并从服务器获取505响应(不支持HTTP版本)。问题是,使用简单的pythonrequests.get可以实现相同的查询。此外,我可以使用Chrome并成功执行相同的请求。有什么想法会使golang请求不同,从而导致服务器返回505吗?我意识到这个响应是特定于服务器的。使用相同的golang代码将HTTPS连接到google.com。我曾尝试使用Wireshark进行故障排除,但TLS使这变得困难。看来这一定很简单!服务器是nginx1.9.3。Golang代码:packagemainimport("fmt""ne

linux - Golang 中的缓冲区问题

我正在处理多线程和序列化流程,并希望自动化我的侦察流程。只要我不调用名为nmap的函数,我的代码就可以正常工作。当调用nmap时,它退出并出现以下错误:./recon-s.go:54:12:notenoughargumentsincalltonmaphave()want(chan这是我的代码:packagemainimport("fmt""log""os/exec""sync")varurlstringvarwgsync.WaitGroupvaripstringfuncnikto(outChanchan 最佳答案 您遇到的错误是:n

json - 更新 1.1 在文件夹中运行 Go 文件和 JSON 文件时出现问题

更新1.1在收到有关更改处理程序路径的有用反馈后,我在我的应用程序中使用了该反馈,但奇怪的是,我仍然收到一些错误反馈。我正在尝试自己弄清楚,但我想我可以与大家分享。这也是我取消现在给出的答案的原因。还有一些答案现在让我感到困惑,无法理解这将如何为我工作。packagemainimport("net/http"//PackagehttpprovidesHTTPclientandserverimplementations.)funcmain(){webHost()}funcwebHost(){//Ikhebhierlaternogeenmapjevoordehtmlpagina'stoeg